home *** CD-ROM | disk | FTP | other *** search
/ BBS in a Box 7 / BBS in a Box - Macintosh - Volume VII (BBS in a Box) (January 1993).iso / Files / DA / P / PCalculator.cpt / CalcDA sources / CalcDA_Functions.c < prev    next >
MacBinary  |  1990-07-06  |  6.3 KB  |  [TEXT/KAHL]

open in: MacOS 8.1     |     Win98     |     DOS

view JSON data     |     view as text

This file was processed as: MacBinary (archive/macBinary).

You can browse this item here: CalcDA_Functions.c

ConfidenceProgramDetectionMatch TypeSupport
66% dexvert Compact Compressed (Unix) (archive/compact) ext Supported
10% dexvert MacBinary (archive/macBinary) fallback Supported
1% dexvert Text File (text/txt) fallback Supported
100% file MacBinary II, inited, Fri Jul 6 17:04:10 1990, modified Fri Jul 6 17:04:10 1990, creator Think C, type ASCII, 5772 bytes "CalcDA_Functions.c" , at 0x170c 348 bytes resource default (weak)
99% file data default
74% TrID Macintosh plain text (MacBinary) default
25% TrID MacBinary 2 default (weak)
100% siegfried fmt/1762 MacBinary (II) default
100% lsar MacBinary default


id metadata
keyvalue
macFileType[TEXT]
macFileCreator[KAHL]



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 12 43 61 6c 63 44 41 | 5f 46 75 6e 63 74 69 6f |..CalcDA|_Functio|
|00000010| 6e 73 2e 63 00 00 00 00 | 00 00 00 00 00 00 00 00 |ns.c....|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 4b 41 48 | 4c 01 00 00 00 00 00 00 |.TEXTKAH|L.......|
|00000050| 00 00 00 00 00 16 8c 00 | 00 01 5c a2 ba ad 4a a2 |........|..\...J.|
|00000060| ba ad 4a 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |..J.....|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 20 f7 00 00 |........|.... ...|
|00000080| 2f 2a 0d 20 2a 20 43 61 | 6c 63 44 41 5f 46 75 6e |/*. * Ca|lcDA_Fun|
|00000090| 63 74 69 6f 6e 73 2e 63 | 20 66 6f 72 20 74 68 65 |ctions.c| for the|
|000000a0| 20 50 72 6f 67 72 61 6d | 6d 65 72 27 73 20 43 61 | Program|mer's Ca|
|000000b0| 6c 63 75 6c 61 74 6f 72 | 20 70 72 6f 6a 65 63 74 |lculator| project|
|000000c0| 20 0d 20 2a 20 0d 20 2a | 20 43 6f 70 79 72 69 67 | . * . *| Copyrig|
|000000d0| 68 74 20 31 39 39 30 2c | 20 50 65 74 65 72 20 4f |ht 1990,| Peter O|
|000000e0| 68 6c 65 72 20 0d 20 2a | 20 0d 20 2a 20 41 6c 6c |hler . *| . * All|
|000000f0| 20 52 69 67 68 74 73 20 | 52 65 73 65 72 76 65 64 | Rights |Reserved|
|00000100| 20 0d 20 2a 20 0d 20 2a | 20 54 68 65 20 50 72 6f | . * . *| The Pro|
|00000110| 67 72 61 6d 6d 65 72 27 | 73 20 43 61 6c 63 75 6c |grammer'|s Calcul|
|00000120| 61 74 6f 72 20 61 6e 64 | 20 74 68 65 20 73 6f 75 |ator and| the sou|
|00000130| 72 63 65 20 63 6f 64 65 | 20 61 72 65 20 73 68 61 |rce code| are sha|
|00000140| 72 65 77 61 72 65 2e 20 | 20 54 68 61 74 20 6d 65 |reware. | That me|
|00000150| 61 6e 73 0d 20 2a 20 74 | 68 65 79 20 61 72 65 20 |ans. * t|hey are |
|00000160| 6e 6f 74 20 66 72 65 65 | 2e 20 20 49 66 20 79 6f |not free|. If yo|
|00000170| 75 20 75 73 65 20 65 69 | 74 68 65 72 20 74 68 65 |u use ei|ther the|
|00000180| 20 73 6f 75 72 63 65 20 | 6f 72 20 74 68 65 20 63 | source |or the c|
|00000190| 61 6c 63 75 6c 61 74 6f | 72 20 74 68 65 6e 0d 20 |alculato|r then. |
|000001a0| 2a 20 73 65 6e 64 20 24 | 35 20 6f 72 20 24 31 30 |* send $|5 or $10|
|000001b0| 20 28 77 68 61 74 65 76 | 65 72 20 79 6f 75 20 66 | (whatev|er you f|
|000001c0| 65 65 6c 20 69 74 73 20 | 77 6f 72 74 68 29 20 74 |eel its |worth) t|
|000001d0| 6f 20 74 68 65 20 61 64 | 64 72 65 73 73 20 74 68 |o the ad|dress th|
|000001e0| 61 74 20 66 6f 6c 6c 6f | 77 73 2e 0d 20 2a 20 54 |at follo|ws.. * T|
|000001f0| 68 65 20 73 6f 75 72 63 | 65 20 61 6e 64 20 63 61 |he sourc|e and ca|
|00000200| 6c 63 75 6c 61 74 6f 72 | 20 63 61 6e 20 62 65 20 |lculator| can be |
|00000210| 64 69 73 74 72 69 62 75 | 74 65 64 20 66 6f 72 20 |distribu|ted for |
|00000220| 66 72 65 65 2e 20 20 50 | 72 69 6f 72 20 74 6f 20 |free. P|rior to |
|00000230| 61 6e 79 20 73 61 6c 65 | 0d 20 2a 20 6f 66 20 65 |any sale|. * of e|
|00000240| 69 74 68 65 72 20 74 68 | 65 20 73 6f 75 72 63 65 |ither th|e source|
|00000250| 20 63 6f 64 65 20 6f 72 | 20 74 68 65 20 63 61 6c | code or| the cal|
|00000260| 63 75 6c 61 74 6f 72 20 | 6d 79 20 70 65 72 6d 69 |culator |my permi|
|00000270| 73 73 69 6f 6e 20 6d 75 | 73 74 20 62 65 0d 20 2a |ssion mu|st be. *|
|00000280| 20 6f 62 74 61 69 6e 65 | 64 2e 20 20 54 68 69 73 | obtaine|d. This|
|00000290| 20 69 6e 63 6c 75 64 65 | 73 20 73 61 6c 65 73 20 | include|s sales |
|000002a0| 62 79 20 73 68 61 72 65 | 77 61 72 65 20 64 69 73 |by share|ware dis|
|000002b0| 74 72 69 62 75 74 69 6f | 6e 20 68 6f 75 73 65 73 |tributio|n houses|
|000002c0| 20 74 68 61 74 20 73 65 | 6c 6c 0d 20 2a 20 73 68 | that se|ll. * sh|
|000002d0| 61 72 65 77 61 72 65 2e | 20 20 0d 20 2a 20 0d 20 |areware.| . * . |
|000002e0| 2a 20 50 65 74 65 72 20 | 4f 68 6c 65 72 20 0d 20 |* Peter |Ohler . |
|000002f0| 2a 20 0d 20 2a 20 33 31 | 38 34 20 52 6f 68 72 65 |* . * 31|84 Rohre|
|00000300| 72 20 44 72 69 76 65 2c | 20 4c 61 66 61 79 65 74 |r Drive,| Lafayet|
|00000310| 74 65 20 43 41 20 39 34 | 35 34 39 20 0d 20 2a 20 |te CA 94|549 . * |
|00000320| 0d 20 2a 20 28 34 31 35 | 29 20 32 38 34 2d 37 38 |. * (415|) 284-78|
|00000330| 32 38 20 0d 20 2a 20 0d | 20 2a 20 2a 2a 2a 2a 2a |28 . * .| * *****|
|00000340| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000350| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000360| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000370| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000380| 2a 2a 2a 2a 2a 2a 0d 20 | 2a 20 0d 20 2a 20 53 6f |******. |* . * So|
|00000390| 6d 65 20 6f 66 20 74 68 | 65 20 66 75 6e 63 74 69 |me of th|e functi|
|000003a0| 6f 6e 73 20 69 6e 20 74 | 68 69 73 20 66 69 6c 65 |ons in t|his file|
|000003b0| 20 61 72 65 20 64 65 72 | 69 76 65 64 20 66 72 6f | are der|ived fro|
|000003c0| 6d 20 74 68 65 20 66 75 | 6e 63 74 69 6f 6e 73 20 |m the fu|nctions |
|000003d0| 70 72 6f 76 69 64 65 64 | 0d 20 2a 20 62 79 20 54 |provided|. * by T|
|000003e0| 48 49 4e 4b 20 43 2e 20 | 20 4d 6f 73 74 20 6f 66 |HINK C. | Most of|
|000003f0| 20 74 68 65 20 66 75 6e | 63 74 69 6f 6e 73 20 69 | the fun|ctions i|
|00000400| 6e 20 74 68 69 73 20 66 | 69 6c 65 20 74 61 6b 65 |n this f|ile take|
|00000410| 20 6f 6e 6c 79 20 6f 6e | 65 20 61 72 67 75 6d 65 | only on|e argume|
|00000420| 6e 74 0d 20 2a 20 28 74 | 68 65 20 58 20 72 65 67 |nt. * (t|he X reg|
|00000430| 69 73 74 65 72 29 20 61 | 6e 64 20 70 6c 61 63 65 |ister) a|nd place|
|00000440| 20 74 68 65 20 72 65 73 | 75 6c 74 20 69 6e 20 74 | the res|ult in t|
|00000450| 68 65 20 58 20 72 65 67 | 69 73 74 65 72 2e 20 20 |he X reg|ister. |
|00000460| 54 68 65 20 72 65 73 74 | 20 6f 66 20 74 68 65 0d |The rest| of the.|
|00000470| 20 2a 20 66 75 6e 63 74 | 69 6f 6e 20 73 74 61 63 | * funct|ion stac|
|00000480| 6b 20 69 73 20 6e 6f 74 | 20 65 66 66 65 63 74 65 |k is not| effecte|
|00000490| 64 20 62 79 20 74 68 65 | 20 65 78 65 63 75 74 69 |d by the| executi|
|000004a0| 6f 6e 20 6f 66 20 74 68 | 65 73 65 20 66 75 6e 63 |on of th|ese func|
|000004b0| 74 69 6f 6e 73 2e 0d 20 | 2a 20 50 6f 77 65 72 28 |tions.. |* Power(|
|000004c0| 29 20 69 73 20 74 68 65 | 20 65 78 63 65 70 74 69 |) is the| excepti|
|000004d0| 6f 6e 20 74 6f 20 74 68 | 69 73 20 67 65 6e 65 72 |on to th|is gener|
|000004e0| 61 6c 69 7a 61 74 69 6f | 6e 2e 20 20 0d 20 2a 2f |alizatio|n. . */|
|000004f0| 0d 0d 23 69 6e 63 6c 75 | 64 65 20 3c 53 41 4e 45 |..#inclu|de <SANE|
|00000500| 2e 68 3e 0d 23 69 6e 63 | 6c 75 64 65 20 22 43 61 |.h>.#inc|lude "Ca|
|00000510| 6c 63 44 41 2e 68 22 0d | 0d 2f 2a 0d 20 2a 20 2a |lcDA.h".|./*. * *|
|00000520| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000530| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000540| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000550| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000560| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 0d 20 2a 20 23 64 |********|**. * #d|
|00000570| 65 66 69 6e 65 73 0d 20 | 2a 2f 0d 23 64 65 66 69 |efines. |*/.#defi|
|00000580| 6e 65 20 52 65 73 65 74 | 28 29 09 09 66 70 36 38 |ne Reset|()..fp68|
|00000590| 6b 28 26 65 6e 76 2c 20 | 46 50 52 4f 43 45 4e 54 |k(&env, |FPROCENT|
|000005a0| 52 59 29 3b 0d 0d 23 64 | 65 66 69 6e 65 20 52 61 |RY);..#d|efine Ra|
|000005b0| 6e 67 65 43 68 65 63 6b | 28 74 61 72 67 65 74 2c |ngeCheck|(target,|
|000005c0| 20 72 65 73 75 6c 74 29 | 09 09 09 5c 0d 09 69 66 | result)|...\..if|
|000005d0| 20 28 28 66 70 36 38 6b | 28 26 65 6e 76 2c 20 46 | ((fp68k|(&env, F|
|000005e0| 47 45 54 45 4e 56 29 2c | 20 65 6e 76 29 20 26 20 |GETENV),| env) & |
|000005f0| 30 78 30 46 30 30 29 20 | 7b 09 5c 0d 09 09 74 61 |0x0F00) |{.\...ta|
|00000600| 72 67 65 74 20 3d 20 72 | 65 73 75 6c 74 3b 09 09 |rget = r|esult;..|
|00000610| 09 5c 0d 09 7d 0d 0d 2f | 2a 0d 20 2a 20 2a 2a 2a |.\..}../|*. * ***|
|00000620| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000630| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000640| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000650| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000660| 2a 2a 2a 2a 2a 2a 2a 2a | 0d 20 2a 20 70 72 6f 74 |********|. * prot|
|00000670| 6f 74 79 70 65 73 20 0d | 20 2a 2f 0d 65 78 74 65 |otypes .| */.exte|
|00000680| 72 6e 20 76 6f 69 64 09 | 55 70 64 61 74 65 58 52 |rn void.|UpdateXR|
|00000690| 65 67 54 65 78 74 28 76 | 6f 69 64 29 3b 0d 65 78 |egText(v|oid);.ex|
|000006a0| 74 65 72 6e 20 76 6f 69 | 64 09 46 72 65 65 7a 65 |tern voi|d.Freeze|
|000006b0| 58 52 65 67 28 76 6f 69 | 64 29 3b 0d 0d 69 6e 74 |XReg(voi|d);..int|
|000006c0| 09 44 6f 58 46 61 63 74 | 6f 72 69 61 6c 28 76 6f |.DoXFact|orial(vo|
|000006d0| 69 64 29 3b 0d 0d 69 6e | 74 09 44 6f 44 65 67 32 |id);..in|t.DoDeg2|
|000006e0| 52 61 64 28 76 6f 69 64 | 29 3b 0d 69 6e 74 09 44 |Rad(void|);.int.D|
|000006f0| 6f 52 61 64 32 44 65 67 | 28 76 6f 69 64 29 3b 0d |oRad2Deg|(void);.|
|00000700| 0d 69 6e 74 09 44 6f 54 | 72 69 67 28 44 6f 75 62 |.int.DoT|rig(Doub|
|00000710| 6c 65 46 75 6e 63 20 66 | 75 6e 63 2c 20 69 6e 74 |leFunc f|unc, int|
|00000720| 20 69 6e 76 29 3b 0d 64 | 6f 75 62 6c 65 09 53 69 | inv);.d|ouble.Si|
|00000730| 6e 65 28 64 6f 75 62 6c | 65 20 78 29 3b 0d 64 6f |ne(doubl|e x);.do|
|00000740| 75 62 6c 65 09 43 6f 73 | 69 6e 65 28 64 6f 75 62 |uble.Cos|ine(doub|
|00000750| 6c 65 20 78 29 3b 0d 64 | 6f 75 62 6c 65 09 54 61 |le x);.d|ouble.Ta|
|00000760| 6e 67 65 6e 74 28 64 6f | 75 62 6c 65 20 78 29 3b |ngent(do|uble x);|
|00000770| 0d 64 6f 75 62 6c 65 09 | 41 72 63 54 61 6e 67 65 |.double.|ArcTange|
|00000780| 6e 74 28 64 6f 75 62 6c | 65 20 78 29 3b 0d 0d 64 |nt(doubl|e x);..d|
|00000790| 6f 75 62 6c 65 09 46 6c | 6f 6f 72 28 64 6f 75 62 |ouble.Fl|oor(doub|
|000007a0| 6c 65 20 78 29 3b 0d 64 | 6f 75 62 6c 65 09 4d 6f |le x);.d|ouble.Mo|
|000007b0| 64 66 28 64 6f 75 62 6c | 65 20 78 2c 20 64 6f 75 |df(doubl|e x, dou|
|000007c0| 62 6c 65 20 2a 6e 70 74 | 72 29 3b 0d 64 6f 75 62 |ble *npt|r);.doub|
|000007d0| 6c 65 09 46 6d 6f 64 28 | 64 6f 75 62 6c 65 20 78 |le.Fmod(|double x|
|000007e0| 2c 20 64 6f 75 62 6c 65 | 20 79 29 3b 0d 64 6f 75 |, double| y);.dou|
|000007f0| 62 6c 65 09 50 6f 77 65 | 72 28 64 6f 75 62 6c 65 |ble.Powe|r(double|
|00000800| 20 78 2c 20 64 6f 75 62 | 6c 65 20 79 29 3b 0d 64 | x, doub|le y);.d|
|00000810| 6f 75 62 6c 65 09 41 53 | 69 6e 28 64 6f 75 62 6c |ouble.AS|in(doubl|
|00000820| 65 20 78 29 3b 0d 64 6f | 75 62 6c 65 09 41 43 6f |e x);.do|uble.ACo|
|00000830| 73 28 64 6f 75 62 6c 65 | 20 78 29 3b 0d 64 6f 75 |s(double| x);.dou|
|00000840| 62 6c 65 09 4c 6f 67 31 | 30 28 64 6f 75 62 6c 65 |ble.Log1|0(double|
|00000850| 20 78 29 3b 0d 0d 2f 2a | 0d 20 2a 20 2a 2a 2a 2a | x);../*|. * ****|
|00000860| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000870| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000880| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000890| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000008a0| 2a 2a 2a 2a 2a 2a 2a 0d | 20 2a 20 76 61 72 69 61 |*******.| * varia|
|000008b0| 62 6c 65 73 20 0d 20 2a | 2f 0d 2f 2a 0d 20 2a 20 |bles . *|/./*. * |
|000008c0| 54 68 65 20 75 73 65 20 | 6f 66 20 76 61 72 69 61 |The use |of varia|
|000008d0| 62 6c 65 20 69 6e 73 74 | 65 61 64 20 6f 66 20 61 |ble inst|ead of a|
|000008e0| 20 23 64 65 66 69 6e 65 | 20 72 65 64 75 63 65 73 | #define| reduces|
|000008f0| 20 74 68 65 20 63 6f 64 | 65 20 73 69 7a 65 20 73 | the cod|e size s|
|00000900| 69 6e 63 65 0d 20 2a 20 | 64 6f 75 62 6c 65 73 20 |ince. * |doubles |
|00000910| 74 61 6b 65 20 75 70 20 | 6d 6f 72 65 20 73 70 61 |take up |more spa|
|00000920| 63 65 20 74 68 61 6e 20 | 61 20 72 65 66 65 72 65 |ce than |a refere|
|00000930| 6e 63 65 20 74 6f 20 61 | 20 76 61 72 69 61 62 6c |nce to a| variabl|
|00000940| 65 2e 0d 20 2a 2f 0d 65 | 78 74 65 72 6e 20 64 6f |e.. */.e|xtern do|
|00000950| 75 62 6c 65 09 50 49 3b | 0d 0d 64 6f 75 62 6c 65 |uble.PI;|..double|
|00000960| 09 5a 65 72 6f 20 3d 20 | 30 2e 30 3b 0d 64 6f 75 |.Zero = |0.0;.dou|
|00000970| 62 6c 65 09 4f 6e 65 20 | 3d 20 31 2e 30 3b 0d 64 |ble.One |= 1.0;.d|
|00000980| 6f 75 62 6c 65 09 4e 65 | 67 4f 6e 65 20 3d 20 2d |ouble.Ne|gOne = -|
|00000990| 31 2e 30 3b 0d 64 6f 75 | 62 6c 65 09 54 77 6f 20 |1.0;.dou|ble.Two |
|000009a0| 3d 20 32 2e 30 3b 0d 64 | 6f 75 62 6c 65 09 4f 6e |= 2.0;.d|ouble.On|
|000009b0| 65 45 69 67 68 74 79 20 | 3d 20 31 38 30 2e 30 3b |eEighty |= 180.0;|
|000009c0| 0d 0d 73 74 61 74 69 63 | 20 73 68 6f 72 74 20 65 |..static| short e|
|000009d0| 6e 76 3b 0d 0d 2f 2a 20 | 48 61 63 6b 73 20 66 6f |nv;../* |Hacks fo|
|000009e0| 72 20 74 68 65 20 4d 41 | 43 20 66 72 6f 6d 20 54 |r the MA|C from T|
|000009f0| 48 49 4e 4b 20 43 20 2a | 2f 0d 73 74 61 74 69 63 |HINK C *|/.static|
|00000a00| 20 73 68 6f 72 74 20 4e | 65 67 49 6e 66 5b 5d 20 | short N|egInf[] |
|00000a10| 3d 09 7b 20 30 78 46 46 | 46 46 2c 20 30 78 30 30 |=.{ 0xFF|FF, 0x00|
|00000a20| 30 30 2c 20 30 78 30 30 | 30 30 2c 20 30 78 30 30 |00, 0x00|00, 0x00|
|00000a30| 30 30 2c 20 30 78 30 30 | 30 30 20 7d 3b 0d 23 64 |00, 0x00|00 };.#d|
|00000a40| 65 66 69 6e 65 20 4e 65 | 67 49 6e 66 09 09 28 2a |efine Ne|gInf..(*|
|00000a50| 20 28 64 6f 75 62 6c 65 | 20 2a 29 20 4e 65 67 49 | (double| *) NegI|
|00000a60| 6e 66 29 0d 73 74 61 74 | 69 63 20 73 68 6f 72 74 |nf).stat|ic short|
|00000a70| 20 49 6e 66 5b 5d 20 3d | 09 7b 20 30 78 37 46 46 | Inf[] =|.{ 0x7FF|
|00000a80| 46 2c 20 30 78 30 30 30 | 30 2c 20 30 78 30 30 30 |F, 0x000|0, 0x000|
|00000a90| 30 2c 20 30 78 30 30 30 | 30 2c 20 30 78 30 30 30 |0, 0x000|0, 0x000|
|00000aa0| 30 20 7d 3b 0d 23 64 65 | 66 69 6e 65 20 49 6e 66 |0 };.#de|fine Inf|
|00000ab0| 09 09 28 2a 20 28 64 6f | 75 62 6c 65 20 2a 29 20 |..(* (do|uble *) |
|00000ac0| 49 6e 66 29 0d 0d 2f 2a | 0d 20 2a 20 2a 2a 2a 2a |Inf)../*|. * ****|
|00000ad0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000ae0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000af0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000b00| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000b10| 2a 2a 2a 2a 2a 2a 2a 0d | 20 2a 20 66 75 6e 63 74 |*******.| * funct|
|00000b20| 69 6f 6e 73 20 0d 20 2a | 2f 0d 2f 2a 0d 20 2a 20 |ions . *|/./*. * |
|00000b30| 41 20 73 69 6d 70 6c 65 | 20 66 61 63 74 6f 72 69 |A simple| factori|
|00000b40| 61 6c 20 66 75 6e 63 74 | 69 6f 6e 2e 20 20 4e 6f |al funct|ion. No|
|00000b50| 74 65 20 74 68 65 20 72 | 61 6e 67 65 20 63 68 65 |te the r|ange che|
|00000b60| 63 6b 20 6f 6e 20 74 68 | 65 20 64 6f 75 62 6c 65 |ck on th|e double|
|00000b70| 20 76 65 72 73 69 6f 6e | 0d 20 2a 20 73 6f 20 74 | version|. * so t|
|00000b80| 68 61 74 20 77 65 20 64 | 6f 6e 27 74 20 67 6f 20 |hat we d|on't go |
|00000b90| 6f 6e 20 66 6f 72 65 76 | 65 72 2e 20 20 54 68 65 |on forev|er. The|
|00000ba0| 20 69 6e 74 65 67 65 72 | 20 76 65 72 73 69 6f 6e | integer| version|
|00000bb0| 20 77 69 6c 6c 20 77 72 | 61 70 20 61 72 6f 75 6e | will wr|ap aroun|
|00000bc0| 64 2e 20 20 49 66 0d 20 | 2a 20 74 68 65 20 77 72 |d. If. |* the wr|
|00000bd0| 61 70 20 69 73 6e 27 74 | 20 77 68 61 74 20 79 6f |ap isn't| what yo|
|00000be0| 75 20 74 68 69 6e 6b 20 | 69 73 20 72 69 67 68 74 |u think |is right|
|00000bf0| 20 74 68 65 6e 20 61 64 | 64 20 61 20 6c 69 6d 69 | then ad|d a limi|
|00000c00| 74 20 63 68 65 63 6b 20 | 28 66 75 74 75 72 65 0d |t check |(future.|
|00000c10| 20 2a 20 76 61 6c 75 65 | 20 63 68 65 63 6b 29 2e | * value| check).|
|00000c20| 20 20 0d 20 2a 2f 0d 69 | 6e 74 0d 44 6f 58 46 61 | . */.i|nt.DoXFa|
|00000c30| 63 74 6f 72 69 61 6c 28 | 29 0d 7b 0d 09 69 66 20 |ctorial(|).{..if |
|00000c40| 28 49 4e 54 45 47 45 52 | 20 3d 3d 20 74 79 70 65 |(INTEGER| == type|
|00000c50| 53 74 61 63 6b 2e 70 6f | 73 29 20 7b 0d 09 09 6c |Stack.po|s) {...l|
|00000c60| 6f 6e 67 09 78 3b 0d 0d | 09 09 66 6f 72 20 28 78 |ong.x;..|..for (x|
|00000c70| 20 3d 20 78 52 65 67 2e | 76 61 6c 75 65 2e 6c 76 | = xReg.|value.lv|
|00000c80| 2c 20 78 52 65 67 2e 76 | 61 6c 75 65 2e 6c 76 20 |, xReg.v|alue.lv |
|00000c90| 3d 20 31 4c 3b 20 78 20 | 3e 20 30 4c 3b 20 78 2d |= 1L; x |> 0L; x-|
|00000ca0| 2d 29 0d 09 09 09 78 52 | 65 67 2e 76 61 6c 75 65 |-)....xR|eg.value|
|00000cb0| 2e 6c 76 20 2a 3d 20 78 | 3b 0d 09 7d 20 65 6c 73 |.lv *= x|;..} els|
|00000cc0| 65 20 7b 0d 09 09 64 6f | 75 62 6c 65 09 78 3b 0d |e {...do|uble.x;.|
|00000cd0| 0d 09 09 66 6f 72 20 28 | 78 20 3d 20 78 52 65 67 |...for (|x = xReg|
|00000ce0| 2e 76 61 6c 75 65 2e 64 | 76 2c 20 78 52 65 67 2e |.value.d|v, xReg.|
|00000cf0| 76 61 6c 75 65 2e 64 76 | 20 3d 20 4f 6e 65 3b 20 |value.dv| = One; |
|00000d00| 78 20 3e 20 5a 65 72 6f | 3b 20 78 20 2d 3d 20 4f |x > Zero|; x -= O|
|00000d10| 6e 65 29 20 7b 0d 09 09 | 09 78 52 65 67 2e 76 61 |ne) {...|.xReg.va|
|00000d20| 6c 75 65 2e 64 76 20 2a | 3d 20 78 3b 0d 09 09 09 |lue.dv *|= x;....|
|00000d30| 69 66 20 28 49 6e 66 20 | 3c 3d 20 78 52 65 67 2e |if (Inf |<= xReg.|
|00000d40| 76 61 6c 75 65 2e 64 76 | 29 0d 09 09 09 09 62 72 |value.dv|).....br|
|00000d50| 65 61 6b 3b 0d 09 09 7d | 0d 09 7d 0d 09 46 72 65 |eak;...}|..}..Fre|
|00000d60| 65 7a 65 58 52 65 67 28 | 29 3b 0d 09 72 65 74 75 |ezeXReg(|);..retu|
|00000d70| 72 6e 20 30 3b 0d 7d 0d | 0d 2f 2a 0d 20 2a 20 2a |rn 0;.}.|./*. * *|
|00000d80| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000d90| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000da0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000db0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000dc0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 0d 20 2a 20 54 72 |********|**. * Tr|
|00000dd0| 69 67 20 66 75 6e 63 74 | 69 6f 6e 73 20 0d 20 2a |ig funct|ions . *|
|00000de0| 2f 0d 2f 2a 0d 20 2a 20 | 54 68 69 73 20 69 73 20 |/./*. * |This is |
|00000df0| 74 68 65 20 67 65 6e 65 | 72 61 6c 20 66 75 6e 63 |the gene|ral func|
|00000e00| 74 69 6f 6e 20 66 6f 72 | 20 65 78 65 63 75 74 69 |tion for| executi|
|00000e10| 6e 67 20 74 72 69 67 20 | 66 75 6e 63 74 69 6f 6e |ng trig |function|
|00000e20| 73 2e 20 20 53 69 6e 63 | 65 20 74 68 69 73 0d 20 |s. Sinc|e this. |
|00000e30| 2a 20 70 6f 72 74 69 6f | 6e 20 6e 65 65 64 73 20 |* portio|n needs |
|00000e40| 74 6f 20 62 65 20 64 6f | 6e 65 20 66 6f 72 20 65 |to be do|ne for e|
|00000e50| 76 65 72 79 20 74 72 69 | 67 20 66 75 6e 63 74 69 |very tri|g functi|
|00000e60| 6f 6e 20 69 74 20 68 61 | 73 20 62 65 65 6e 20 70 |on it ha|s been p|
|00000e70| 75 6c 6c 65 64 20 69 6e | 74 6f 0d 20 2a 20 6f 6e |ulled in|to. * on|
|00000e80| 65 20 66 75 6e 63 74 69 | 6f 6e 20 74 68 61 74 20 |e functi|on that |
|00000e90| 63 61 6c 6c 73 20 74 68 | 65 20 6c 6f 77 20 6c 65 |calls th|e low le|
|00000ea0| 76 65 6c 20 74 72 69 67 | 20 66 75 6e 63 74 69 6f |vel trig| functio|
|00000eb0| 6e 20 68 61 6e 64 65 64 | 20 74 6f 20 69 74 20 61 |n handed| to it a|
|00000ec0| 73 20 74 68 65 0d 20 2a | 20 66 69 72 73 74 20 61 |s the. *| first a|
|00000ed0| 72 67 75 6d 65 6e 74 2e | 20 20 0d 20 2a 2f 0d 69 |rgument.| . */.i|
|00000ee0| 6e 74 0d 44 6f 54 72 69 | 67 28 66 75 6e 63 2c 20 |nt.DoTri|g(func, |
|00000ef0| 69 6e 76 29 0d 09 44 6f | 75 62 6c 65 46 75 6e 63 |inv)..Do|ubleFunc|
|00000f00| 09 66 75 6e 63 3b 0d 09 | 69 6e 74 09 09 69 6e 76 |.func;..|int..inv|
|00000f10| 3b 0d 7b 0d 09 69 66 20 | 28 49 4e 54 45 47 45 52 |;.{..if |(INTEGER|
|00000f20| 20 3d 3d 20 74 79 70 65 | 53 74 61 63 6b 2e 70 6f | == type|Stack.po|
|00000f30| 73 29 20 7b 0d 09 09 72 | 65 74 75 72 6e 20 2d 31 |s) {...r|eturn -1|
|00000f40| 3b 0d 09 7d 20 65 6c 73 | 65 20 7b 0d 09 09 69 66 |;..} els|e {...if|
|00000f50| 20 28 52 41 44 49 41 4e | 53 20 3d 3d 20 61 6e 67 | (RADIAN|S == ang|
|00000f60| 6c 65 53 74 61 63 6b 2e | 70 6f 73 29 0d 09 09 09 |leStack.|pos)....|
|00000f70| 78 52 65 67 2e 76 61 6c | 75 65 2e 64 76 20 3d 20 |xReg.val|ue.dv = |
|00000f80| 28 2a 66 75 6e 63 29 28 | 78 52 65 67 2e 76 61 6c |(*func)(|xReg.val|
|00000f90| 75 65 2e 64 76 29 3b 0d | 09 09 65 6c 73 65 20 7b |ue.dv);.|..else {|
|00000fa0| 0d 09 09 09 69 66 20 28 | 69 6e 76 29 0d 09 09 09 |....if (|inv)....|
|00000fb0| 09 78 52 65 67 2e 76 61 | 6c 75 65 2e 64 76 20 3d |.xReg.va|lue.dv =|
|00000fc0| 20 28 2a 66 75 6e 63 29 | 28 78 52 65 67 2e 76 61 | (*func)|(xReg.va|
|00000fd0| 6c 75 65 2e 64 76 29 20 | 2a 20 4f 6e 65 45 69 67 |lue.dv) |* OneEig|
|00000fe0| 68 74 79 20 2f 20 50 49 | 3b 0d 09 09 09 65 6c 73 |hty / PI|;....els|
|00000ff0| 65 0d 09 09 09 09 78 52 | 65 67 2e 76 61 6c 75 65 |e.....xR|eg.value|
|00001000| 2e 64 76 20 3d 20 28 2a | 66 75 6e 63 29 28 78 52 |.dv = (*|func)(xR|
|00001010| 65 67 2e 76 61 6c 75 65 | 2e 64 76 20 2a 20 50 49 |eg.value|.dv * PI|
|00001020| 20 2f 20 4f 6e 65 45 69 | 67 68 74 79 29 3b 0d 09 | / OneEi|ghty);..|
|00001030| 09 7d 0d 09 7d 0d 09 46 | 72 65 65 7a 65 58 52 65 |.}..}..F|reezeXRe|
|00001040| 67 28 29 3b 0d 09 72 65 | 74 75 72 6e 20 30 3b 0d |g();..re|turn 0;.|
|00001050| 7d 0d 0d 2f 2a 0d 20 2a | 20 54 68 65 73 65 20 61 |}../*. *| These a|
|00001060| 72 65 20 74 68 65 20 61 | 63 74 75 61 6c 20 6f 72 |re the a|ctual or|
|00001070| 20 6c 6f 77 20 6c 65 76 | 65 6c 20 74 72 69 67 20 | low lev|el trig |
|00001080| 66 75 6e 63 74 69 6f 6e | 73 2e 20 20 0d 20 2a 2f |function|s. . */|
|00001090| 0d 64 6f 75 62 6c 65 0d | 53 69 6e 65 28 78 29 0d |.double.|Sine(x).|
|000010a0| 09 64 6f 75 62 6c 65 09 | 78 3b 0d 7b 0d 09 72 65 |.double.|x;.{..re|
|000010b0| 74 75 72 6e 20 73 69 6e | 28 78 29 3b 0d 7d 0d 0d |turn sin|(x);.}..|
|000010c0| 64 6f 75 62 6c 65 0d 43 | 6f 73 69 6e 65 28 78 29 |double.C|osine(x)|
|000010d0| 0d 09 64 6f 75 62 6c 65 | 09 78 3b 0d 7b 0d 09 72 |..double|.x;.{..r|
|000010e0| 65 74 75 72 6e 20 63 6f | 73 28 78 29 3b 0d 7d 0d |eturn co|s(x);.}.|
|000010f0| 0d 64 6f 75 62 6c 65 0d | 54 61 6e 67 65 6e 74 28 |.double.|Tangent(|
|00001100| 78 29 0d 09 64 6f 75 62 | 6c 65 09 78 3b 0d 7b 0d |x)..doub|le.x;.{.|
|00001110| 09 72 65 74 75 72 6e 20 | 74 61 6e 28 78 29 3b 0d |.return |tan(x);.|
|00001120| 7d 0d 0d 64 6f 75 62 6c | 65 0d 41 72 63 54 61 6e |}..doubl|e.ArcTan|
|00001130| 67 65 6e 74 28 78 29 0d | 09 64 6f 75 62 6c 65 09 |gent(x).|.double.|
|00001140| 78 3b 0d 7b 0d 09 72 65 | 74 75 72 6e 20 61 74 61 |x;.{..re|turn ata|
|00001150| 6e 28 78 29 3b 0d 7d 0d | 0d 64 6f 75 62 6c 65 0d |n(x);.}.|.double.|
|00001160| 41 53 69 6e 28 78 29 0d | 09 64 6f 75 62 6c 65 20 |ASin(x).|.double |
|00001170| 78 3b 0d 7b 0d 09 69 66 | 20 28 78 20 3e 20 4f 6e |x;.{..if| (x > On|
|00001180| 65 20 7c 7c 20 78 20 3c | 20 4e 65 67 4f 6e 65 29 |e || x <| NegOne)|
|00001190| 0d 09 09 72 65 74 75 72 | 6e 20 5a 65 72 6f 3b 0d |...retur|n Zero;.|
|000011a0| 0d 09 72 65 74 75 72 6e | 20 28 61 74 61 6e 28 78 |..return| (atan(x|
|000011b0| 20 2f 20 73 71 72 74 28 | 4f 6e 65 20 2d 20 78 20 | / sqrt(|One - x |
|000011c0| 2a 20 78 29 29 29 3b 0d | 7d 0d 0d 64 6f 75 62 6c |* x)));.|}..doubl|
|000011d0| 65 0d 41 43 6f 73 28 78 | 29 0d 09 64 6f 75 62 6c |e.ACos(x|)..doubl|
|000011e0| 65 20 78 3b 0d 7b 0d 09 | 69 66 20 28 78 20 3e 20 |e x;.{..|if (x > |
|000011f0| 4f 6e 65 20 7c 7c 20 78 | 20 3c 20 4e 65 67 4f 6e |One || x| < NegOn|
|00001200| 65 29 0d 09 09 72 65 74 | 75 72 6e 20 5a 65 72 6f |e)...ret|urn Zero|
|00001210| 3b 0d 0d 09 72 65 74 75 | 72 6e 20 28 54 77 6f 20 |;...retu|rn (Two |
|00001220| 2a 20 61 74 61 6e 28 73 | 71 72 74 28 28 4f 6e 65 |* atan(s|qrt((One|
|00001230| 20 2d 20 78 29 20 2f 20 | 28 4f 6e 65 20 2b 20 78 | - x) / |(One + x|
|00001240| 29 29 29 29 3b 0d 7d 0d | 0d 2f 2a 0d 20 2a 20 2a |))));.}.|./*. * *|
|00001250| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001260| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001270| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001280| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001290| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 0d 20 2a 20 53 75 |********|**. * Su|
|000012a0| 70 70 6f 72 74 20 66 75 | 6e 63 74 69 6f 6e 73 20 |pport fu|nctions |
|000012b0| 0d 20 2a 2f 0d 2f 2a 0d | 20 2a 20 52 6f 75 6e 64 |. */./*.| * Round|
|000012c0| 73 20 6f 66 66 20 74 6f | 20 74 68 65 20 6e 65 78 |s off to| the nex|
|000012d0| 74 20 6c 6f 77 65 73 74 | 20 69 6e 74 65 67 65 72 |t lowest| integer|
|000012e0| 20 76 61 6c 75 65 2e 20 | 20 0d 20 2a 2f 0d 64 6f | value. | . */.do|
|000012f0| 75 62 6c 65 0d 46 6c 6f | 6f 72 28 78 29 0d 09 64 |uble.Flo|or(x)..d|
|00001300| 6f 75 62 6c 65 20 78 3b | 0d 7b 0d 09 65 6e 76 20 |ouble x;|.{..env |
|00001310| 3d 20 30 78 34 30 30 30 | 3b 0d 09 66 70 36 38 6b |= 0x4000|;..fp68k|
|00001320| 28 26 65 6e 76 2c 20 46 | 53 45 54 45 4e 56 29 3b |(&env, F|SETENV);|
|00001330| 0d 09 66 70 36 38 6b 28 | 26 78 2c 20 46 52 49 4e |..fp68k(|&x, FRIN|
|00001340| 54 58 29 3b 0d 09 52 65 | 73 65 74 28 29 3b 0d 09 |TX);..Re|set();..|
|00001350| 72 65 74 75 72 6e 20 28 | 78 29 3b 0d 7d 0d 0d 64 |return (|x);.}..d|
|00001360| 6f 75 62 6c 65 0d 4d 6f | 64 66 28 78 2c 20 6e 70 |ouble.Mo|df(x, np|
|00001370| 74 72 29 0d 09 64 6f 75 | 62 6c 65 20 78 3b 0d 09 |tr)..dou|ble x;..|
|00001380| 72 65 67 69 73 74 65 72 | 20 64 6f 75 62 6c 65 20 |register| double |
|00001390| 2a 6e 70 74 72 3b 0d 7b | 0d 09 2a 6e 70 74 72 20 |*nptr;.{|..*nptr |
|000013a0| 3d 20 78 3b 0d 09 66 70 | 36 38 6b 28 6e 70 74 72 |= x;..fp|68k(nptr|
|000013b0| 2c 20 46 54 49 4e 54 58 | 29 3b 0d 09 72 65 74 75 |, FTINTX|);..retu|
|000013c0| 72 6e 20 28 78 20 2d 20 | 2a 6e 70 74 72 29 3b 0d |rn (x - |*nptr);.|
|000013d0| 7d 0d 0d 64 6f 75 62 6c | 65 0d 46 6d 6f 64 28 78 |}..doubl|e.Fmod(x|
|000013e0| 2c 20 79 29 0d 09 64 6f | 75 62 6c 65 20 78 2c 20 |, y)..do|uble x, |
|000013f0| 79 3b 0d 7b 0d 09 64 6f | 75 62 6c 65 20 7a 20 3d |y;.{..do|uble z =|
|00001400| 20 78 3b 0d 0d 09 69 66 | 20 28 5a 65 72 6f 20 3d | x;...if| (Zero =|
|00001410| 3d 20 79 29 0d 09 09 72 | 65 74 75 72 6e 20 5a 65 |= y)...r|eturn Ze|
|00001420| 72 6f 3b 0d 09 66 70 36 | 38 6b 28 26 79 2c 20 46 |ro;..fp6|8k(&y, F|
|00001430| 41 42 53 58 29 3b 0d 09 | 66 70 36 38 6b 28 26 79 |ABSX);..|fp68k(&y|
|00001440| 2c 20 26 7a 2c 20 46 52 | 45 4d 58 29 3b 0d 09 69 |, &z, FR|EMX);..i|
|00001450| 66 20 28 78 20 3e 20 5a | 65 72 6f 20 26 26 20 7a |f (x > Z|ero && z|
|00001460| 20 3c 20 5a 65 72 6f 29 | 0d 09 09 7a 20 2b 3d 20 | < Zero)|...z += |
|00001470| 79 3b 0d 09 65 6c 73 65 | 20 69 66 20 28 78 20 3c |y;..else| if (x <|
|00001480| 20 5a 65 72 6f 20 26 26 | 20 7a 20 3e 20 5a 65 72 | Zero &&| z > Zer|
|00001490| 6f 29 0d 09 09 7a 20 2d | 3d 20 79 3b 0d 09 72 65 |o)...z -|= y;..re|
|000014a0| 74 75 72 6e 20 28 7a 29 | 3b 0d 7d 0d 0d 64 6f 75 |turn (z)|;.}..dou|
|000014b0| 62 6c 65 0d 50 6f 77 65 | 72 28 78 2c 20 79 29 0d |ble.Powe|r(x, y).|
|000014c0| 09 64 6f 75 62 6c 65 20 | 78 2c 20 79 3b 0d 7b 0d |.double |x, y;.{.|
|000014d0| 09 69 6e 74 20 6f 64 64 | 20 3d 20 30 3b 0d 09 0d |.int odd| = 0;...|
|000014e0| 09 69 66 20 28 78 20 3d | 3d 20 5a 65 72 6f 29 20 |.if (x =|= Zero) |
|000014f0| 7b 0d 09 09 69 66 20 28 | 79 20 3c 3d 20 5a 65 72 |{...if (|y <= Zer|
|00001500| 6f 29 0d 09 09 09 72 65 | 74 75 72 6e 20 4e 65 67 |o)....re|turn Neg|
|00001510| 49 6e 66 3b 0d 09 09 72 | 65 74 75 72 6e 28 5a 65 |Inf;...r|eturn(Ze|
|00001520| 72 6f 29 3b 0d 09 7d 0d | 09 69 66 20 28 79 20 3d |ro);..}.|.if (y =|
|00001530| 3d 20 5a 65 72 6f 29 0d | 09 09 72 65 74 75 72 6e |= Zero).|..return|
|00001540| 28 4f 6e 65 29 3b 0d 09 | 69 66 20 28 78 20 3c 20 |(One);..|if (x < |
|00001550| 5a 65 72 6f 29 20 7b 0d | 09 09 69 66 20 28 4d 6f |Zero) {.|..if (Mo|
|00001560| 64 66 28 79 2c 20 26 79 | 29 29 0d 09 09 09 72 65 |df(y, &y|))....re|
|00001570| 74 75 72 6e 20 4e 65 67 | 49 6e 66 3b 0d 09 09 78 |turn Neg|Inf;...x|
|00001580| 20 3d 20 2d 78 3b 0d 09 | 09 6f 64 64 20 3d 20 46 | = -x;..|.odd = F|
|00001590| 6d 6f 64 28 79 2c 20 54 | 77 6f 29 3b 0d 09 7d 0d |mod(y, T|wo);..}.|
|000015a0| 09 52 65 73 65 74 28 29 | 3b 0d 09 65 6c 65 6d 73 |.Reset()|;..elems|
|000015b0| 36 38 6b 28 26 79 2c 20 | 26 78 2c 20 46 58 50 57 |68k(&y, |&x, FXPW|
|000015c0| 52 59 29 3b 0d 09 52 61 | 6e 67 65 43 68 65 63 6b |RY);..Ra|ngeCheck|
|000015d0| 28 78 2c 20 49 6e 66 29 | 3b 0d 09 72 65 74 75 72 |(x, Inf)|;..retur|
|000015e0| 6e 20 28 6f 64 64 20 3f | 20 2d 78 20 3a 20 78 29 |n (odd ?| -x : x)|
|000015f0| 3b 0d 7d 0d 0d 2f 2a 0d | 20 2a 20 48 65 72 65 27 |;.}../*.| * Here'|
|00001600| 73 20 74 68 65 20 6c 6f | 67 20 66 75 6e 63 74 69 |s the lo|g functi|
|00001610| 6f 6e 20 28 6e 6f 74 20 | 74 68 65 20 6c 6e 20 66 |on (not |the ln f|
|00001620| 75 6e 63 74 69 6f 6e 29 | 2e 20 20 4d 61 6e 79 20 |unction)|. Many |
|00001630| 74 68 61 6e 6b 73 20 74 | 6f 20 54 48 49 4e 4b 20 |thanks t|o THINK |
|00001640| 43 20 0d 20 2a 2f 0d 64 | 6f 75 62 6c 65 0d 4c 6f |C . */.d|ouble.Lo|
|00001650| 67 31 30 28 78 29 0d 09 | 64 6f 75 62 6c 65 20 78 |g10(x)..|double x|
|00001660| 3b 0d 7b 0d 09 69 66 20 | 28 78 20 3c 20 5a 65 72 |;.{..if |(x < Zer|
|00001670| 6f 29 0d 09 09 72 65 74 | 75 72 6e 20 4e 65 67 49 |o)...ret|urn NegI|
|00001680| 6e 66 3b 0d 0d 09 52 65 | 73 65 74 28 29 3b 0d 09 |nf;...Re|set();..|
|00001690| 65 6c 65 6d 73 36 38 6b | 28 26 78 2c 20 46 4c 4f |elems68k|(&x, FLO|
|000016a0| 47 32 58 29 3b 09 2f 2a | 20 4c 4f 47 32 20 69 73 |G2X);./*| LOG2 is|
|000016b0| 20 6d 75 63 68 20 66 61 | 73 74 65 72 20 74 68 61 | much fa|ster tha|
|000016c0| 6e 20 4c 4e 20 2a 2f 0d | 09 78 20 2f 3d 20 33 2e |n LN */.|.x /= 3.|
|000016d0| 33 32 31 39 32 38 30 39 | 34 38 38 37 33 36 32 33 |32192809|48873623|
|000016e0| 34 38 3b 0d 09 52 61 6e | 67 65 43 68 65 63 6b 28 |48;..Ran|geCheck(|
|000016f0| 78 2c 20 4e 65 67 49 6e | 66 29 3b 0d 09 72 65 74 |x, NegIn|f);..ret|
|00001700| 75 72 6e 20 28 78 29 3b | 0d 7d 0d 0d 00 00 00 00 |urn (x);|.}......|
|00001710| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001720| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001730| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001740| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001750| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001760| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001770| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001780| 00 00 01 00 00 00 01 16 | 00 00 00 16 00 00 00 46 |........|.......F|
|00001790| 00 00 30 5a 00 73 03 00 | 00 00 00 00 00 00 00 00 |..0Z.s..|........|
|000017a0| 00 00 30 52 07 73 6f 75 | 72 63 65 73 00 00 00 00 |..0R.sou|rces....|
|000017b0| 12 43 61 6c 63 44 41 5f | 46 75 6e 63 74 69 6f 6e |.CalcDA_|Function|
|000017c0| 73 2e 63 69 02 00 00 00 | 54 45 58 54 4b 41 48 4c |s.ci....|TEXTKAHL|
|000017d0| 00 00 54 45 58 54 4b 41 | 48 4c 00 00 00 5a 00 60 |..TEXTKA|HL...Z.`|
|000017e0| 00 00 37 ec 00 00 00 00 | 00 00 00 00 00 00 00 00 |..7.....|........|
|000017f0| 00 00 a2 89 36 00 00 00 | 16 8c 00 00 01 5c 9f d0 |....6...|.....\..|
|00001800| 6b 34 a0 c7 fc b6 00 00 | 00 00 40 25 00 00 00 00 |k4......|..@%....|
|00001810| 00 00 00 00 00 00 00 00 | 00 00 00 00 74 d1 00 05 |........|....t...|
|00001820| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001830| 00 00 00 00 00 00 00 00 | 0d 00 00 00 30 5a 07 61 |........|....0Z.a|
|00001840| 72 69 74 68 2e 63 02 00 | 00 00 54 45 58 54 4b 41 |rith.c..|..TEXTKA|
|00001850| 48 4c 01 00 00 00 00 80 | 00 00 00 00 30 76 00 00 |HL......|....0v..|
|00001860| 00 00 02 0f 00 00 04 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001870| 00 00 a0 38 3f ca a0 9c | de 15 00 00 00 00 40 25 |...8?...|......@%|
|00001880| 00 00 00 04 00 06 00 08 | 00 00 00 0a 00 09 06 4d |........|.......M|
|00001890| 6f 6e 61 63 6f 2b 00 00 | 01 00 00 00 01 16 00 00 |onaco+..|........|
|000018a0| 00 16 00 00 00 46 00 22 | 58 44 06 fc 00 00 00 1c |.....F."|XD......|
|000018b0| 00 46 00 01 45 54 41 42 | 00 00 00 12 45 46 4e 54 |.F..ETAB|....EFNT|
|000018c0| 00 00 00 1e 03 ec ff ff | 00 00 00 00 00 22 57 38 |........|....."W8|
|000018d0| 03 eb ff ff 00 00 00 08 | 00 22 57 28 00 00 00 00 |........|."W(....|
|000018e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000018f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
+--------+-------------------------+-------------------------+--------+--------+